我正在测试一些Ruby代码并且有一个失败的Test::Unit::TestCase。不幸的是,失败报告只给我最上面的错误,而不是完整的堆栈跟踪。具体来说,它说:1)Failure:test_tp_make(TestScripts::TestTpMake)[test/test_scripts.rb:73]:Exceptionraised:>.引用的行号(73)是我的测试用例中assert_nothing_raised代码块的开始,它又开始了另一个代码块,该代码块又调用了一个大型库。我已经尝试使用--verbose标志运行测试,不幸的是这不会改变异常输出。我尝试查阅Test::Unit文档
我有以下代码:classBookPriceattr_accessor:pricedefinitialize(price)@price=priceenddefprice_in_centsInteger(price*100+0.5)endendb=BookPrice.new(2.20)putsb.price_in_cents这一切都运作良好并产生220。但是当我将第二行attr_accessor:price替换为:defprice@price=priceend我收到堆栈级别太深(SystemStackError)错误。这是怎么回事?我知道我可以将Integer(price*100+0.5)
似乎为C程序或Ruby程序(使用C堆栈)设置堆栈大小的推荐方法是使用ulimit。在Bash外壳中。但是$ulimit-s8192$ulimit-s16384-bash:ulimit:stacksize:cannotmodifylimit:Operationnotpermitted和sudo也没有帮助。有没有办法将其设置为16MB、32MB或64MB?我认为应该有一种方法可以在每次程序调用时设置它,而不是同时设置系统范围的参数?现在8192可能意味着8MB,如果与一个进程可以使用的内存量相比,这是非常小的,有时最多2GB的RAM。(更新注释:ulimit-a可以显示其当前值)。(更新2
我在使用Ruby1.8.7和Rails时遇到堆栈级别太深的错误3.0.4并使用Rails控制台执行了以下命令。leo%>railsconsoleLoadingdevelopmentenvironment(Rails3.0.4)ruby-1.8.7-head>leo=Organization.find(1)SystemStackError:stackleveltoodeepfrom/app/models/organization.rb:105:in`parents'这是有问题的对象..classOrganization:delete_allhas_many:groups,:through
在Ruby1.9.2堆栈跟踪中,我经常看到给出的方法为,如下面的堆栈部分所示。这是什么意思?我的Ruby安装有什么问题吗?Couldnotfindabstract-1.0.0inanyofthesources/usr/local/lib/ruby/gems/1.9.1/gems/bundler-1.0.13/lib/bundler/spec_set.rb:87:in`blockinmaterialize'/usr/local/lib/ruby/gems/1.9.1/gems/bundler-1.0.13/lib/bundler/spec_set.rb:81:in`map!'/usr/l
在stackoverflow.com上发布一个堆栈溢出问题,多么有趣:-)我正在运行一些递归Ruby代码,我得到:“堆栈级别太深(SystemStackError)”(我很确定代码有效,我没有陷入无限递归的死亡螺旋,但这不是重点)是否可以更改我的Ruby应用程序允许的堆栈深度/大小?如果这是Ruby中的限制,我不太明白,因为错误显示“堆栈级别”,这给我的印象是Ruby以某种方式计算堆栈的“级别”,或者它只是意味着堆栈满了。我已经尝试在Vista和Ubuntu下运行这个程序,结果相同。在Ubuntu下,我尝试使用“ulimit-s”将堆栈大小从8192更改为16000,但这并没有改变任何
我正在研究不同的优化技术,我发现了这篇文章AnalyzingCodeforEfficiency?相信对调用堆栈进行采样比使用分析器更有效的人。基本思想是,如果您查看调用堆栈,您会看到您的应用程序最有可能花费大部分时间的地方,然后在那里进行优化。这当然很有趣,而且他显然是这方面的专家,但我不知道如何在ruby中查看调用堆栈。在调试器中,我可以说“信息堆栈”,但似乎只显示一行。编辑:我看到MikeDunlavey的评论:“我只想指出,如果你在调试器下运行,手动中断它,并显示调用堆栈......”我只是不确定如何手动中断它并隐藏调用堆栈。 最佳答案
这个问题在这里已经有了答案:HowdoIgetrubytoprintafullbacktraceinsteadofatruncatedone?(10个答案)关闭3年前。我刚收到这个错误信息:...fromc:/ruby/lib/ruby/gems/1.8/gems/......10levels...fromc:/ruby/lib/ruby/gems/1.8/gems/......并且错误(当然)隐藏在...10级...的某处。如何强制Ruby显示完整的堆栈跟踪?
我正在尝试在Rails4.0.8中运行新创建的项目,但我收到错误消息:railss=>BootingWEBrick=>Rails4.0.8applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Run`railsserver-h`formorestartupoptions=>Ctrl-Ctoshutdownserver/usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:12
我需要在Ruby中获取堆栈跟踪对象;不要打印它,只是让它做一些记录和转储以供以后分析。那可能吗?怎么办? 最佳答案 您可以使用Kernel.caller为了这。为异常生成堆栈跟踪时使用相同的方法。来自文档:defa(skip)caller(skip)enddefb(skip)a(skip)enddefc(skip)b(skip)endc(0)#=>["prog:2:in`a'","prog:5:in`b'","prog:8:in`c'","prog:10"]c(1)#=>["prog:5:in`b'","prog:8:in`c'",